## CS433 Written Homework 5

(70 points) All question numbers refer to exercises in the textbook (10th edition). Make sure you use the right textbook and answer the right questions. Students must finish written questions individually. Type your answers and necessary steps clearly.

- **1.** (10 points) 9.13 Given six memory partitions of 100 MB, 170 MB, 40 MB, 205 MB, 300 MB, and 185 MB (in order), how would the first-fit, best-fit, and worst-fit algorithms place processes of size 200 MB, 15 MB, 185 MB, 75 MB, 175 MB, and 80 MB (in order)? Indicate which—if any—requests cannot be satisfied. Comment on how efficiently each of the algorithms manages memory.
- **2. (5 points) 9.15** Compare the memory organization schemes of contiguous memory allocation and paging with respect to the following issues:
  - a. External fragmentation
  - b. Internal fragmentation
  - c. Ability to share code across processes
- **3. (10 points) 9.21** Assuming a 1-KB page size, what are the page numbers and offsets for the following address references (provided as decimal numbers)?
  - a. 21205
  - b. 164250
  - c. 121357
  - d. 16479315
  - e. 27253187
- **4. (5 points) 9.22** The MPV operating system is designed for embedded systems and has a 24-bit virtual address, a 20-bit physical address, and a 4-KB page size. How many entries are there in each of the following?
  - a. A conventional, single-level page table
  - b. An inverted page table

What is the maximum amount of physical memory in the MPV operating system?

- **5. (5 points) 9.23** Consider a logical address space of 2,048 pages with a 4-KB page size, mapped onto a physical memory of 512 frames.
  - a. How many bits are required in the logical address?
  - b. How many bits are required in the physical address?

- **6. (5 points) 9.25** Consider a paging system with the page table stored in memory.
  - a. If a memory reference takes 50 nanoseconds, how long does a paged memory reference take?
  - b. If we add TLBs, and 75 percent of all page-table references are found in the TLBs, what is the effective memory reference time? (Assume that finding a page-table entry in the TLBs takes 2 nanoseconds, if the entry is present.)
- **7. (5 points) 10.16** A simplified view of thread states is ready, running, and blocked, where a thread is either ready and waiting to be scheduled, is running on the processor, or is blocked (for example, waiting for I/O).



Assuming a thread is in the running state, answer the following questions, and explain your answers:

- a. Will the thread change state if it incurs a page fault? If so, to what state will it change?
- b. Will the thread change state if it generates a TLB miss that is resolved in the page table? If so, to what state will it change?
- c. Will the thread change state if an address reference is resolved in the page table? If so, to what state will it change?
- **8. (5 points) 10.21** Assume we have a demand-paged memory. The page table is held in registers. It takes 8 milliseconds to service a page fault if an empty page is available or the replaced page is not modified, and 20 milliseconds if the replaced page is modified. Memory access time is 100 nanoseconds.

Assume that the page to be replaced is modified 70 percent of the time. What is the maximum acceptable page-fault rate for an effective access time of no more than 200 nanoseconds?

**9. (10 points) 10.22** Consider the page table for a system with 16-bit virtual and physical addresses and 4,096-byte pages.

| Page | Page Frame | Reference Bit |
|------|------------|---------------|
| 0    | 9          | 0             |
| 1    | _          | 0             |
| 2    | 10         | 0             |
| 3    | 15         | 0             |
| 4    | 6          | 0             |
| 5    | 13         | 0             |
| 6    | 8          | 0             |
| 7    | 12         | 0             |
| 8    | 7          | 0             |
| 9    | _          | 0             |
| 10   | 5          | 0             |
| 11   | 4          | 0             |
| 12   | 1          | 0             |
| 13   | 0          | 0             |
| 14   | _          | 0             |
| 15   | 2          | 0             |

The reference bit for a page is set to 1 when the page has been referenced. Periodically, a thread zeroes out all values of the reference bit. A dash for a page frame indicates that the page is not in memory. The page-replacement algorithm is localized LRU, and all numbers are provided in decimal.

- a. Convert the following virtual addresses (in hexadecimal) to the equivalent physical addresses. You may provide answers in either hexadecimal or decimal. Also set the reference bit for the appropriate entry in the page table.
  - 0x621C
  - 0xF0A3
  - 0xBC1A
  - 0x5BAA
  - 0x0BA1
- b. Using the above addresses as a guide, provide an example of a logical address (in hexadecimal) that results in a page fault.
- c. From what set of page frames will the LRU page-replacement algorithm choose in resolving a page fault?
- **10 (10 points) 10.24** Apply the (1) FIFO, (2) LRU, and (3) optimal (OPT) replacement algorithms for the following page-reference strings:

- 2,6,9,2,4,2,1,7,3,0,5,2,1,2,9,5,7,3,8,5
- 3,1,4,2,5,4,1,3,5,2,0,1,1,0,2,3,4,5,0,1

Indicate the number of page faults for each algorithm assuming demand paging with three frames. (You only need to do the two above sequences)